<template>
	<view class="container">
		<view class="wrapper">
			<view class="input-content">
				<view class="cu-form-group"
					style="border: 2upx solid whitesmoke;margin-bottom: 20px;border-radius: 30px">
					<view class="title">手机号</view>
					<input type="number" :value="mobile" placeholder="请输入手机号" maxlength="11" data-key="mobile"
						@input="inputChange" />
				</view>
				<!-- <view class="cu-form-group"
					style="border: 2upx solid whitesmoke;margin-bottom: 20px;border-radius: 30px">
					<text class="title">验证码</text>
					<input type="number" :value="code" placeholder="请输入验证码" maxlength="6" data-key="code"
						@input="inputChange" @confirm="toLogin" />
					<button class="send-msg" @click="sendMsg" :disabled="sending">{{ sendTime }}</button>
				</view> -->

				<view class="cu-form-group"
					style="border: 2upx solid whitesmoke;margin-bottom: 20px;border-radius: 30px">
					<text class="title">设置密码</text>
					<input type="password" :value="password" placeholder="请设置新密码" placeholder-class="input-empty"
						maxlength="20" minlength="6" data-key="password" @input="inputChange" @confirm="toLogin" />
				</view>
				<view class="cu-form-group"
					style="border: 2upx solid whitesmoke;margin-bottom: 20px;border-radius: 30px">
					<text class="title">邀请码</text>
					<input type="text" v-if="registerCode == '是'" :value="invitation" placeholder="请填写邀请码"
						data-key="invitation" maxlength="20" @input="inputChange" @confirm="toLogin" />
					<input type="text" v-if="registerCode == '否'" :value="invitation" placeholder="请填写邀请码(选填)"
						data-key="invitation" maxlength="20" @input="inputChange" @confirm="toLogin" />
				</view>
			</view>
			<button class="confirm-btn" @click="toLogin">立即注册</button>
			<view class="footer">
				<text @tap="isShowAgree" class="cuIcon"
					:class="showAgree ? 'cuIcon-radiobox' : 'cuIcon-round'">同意</text>
				<!-- 协议地址 -->
				<navigator url="/me/setting/mimi" open-type="navigate">《隐私政策》</navigator>
				和
				<navigator url="/me/setting/xieyi" open-type="navigate">《用户协议》</navigator>
			</view>
		</view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				showAgree: false,
				code: '',
				mobile: '',
				password: '',
				sending: false,
				sendTime: '获取验证码',
				count: 60,
				relation: "",
				invitation: '',
				registerCode: '',
				qdCodeion: '', //渠道码
			};
		},
		onLoad() {
			if (uni.getStorageSync('qdCodeion')) {
				this.qdCodeion = uni.getStorageSync('qdCodeion')
			}
			let relation = uni.getStorageSync('invitation')
			if (relation) {
				this.relation = relation;
				this.invitation = relation;
			}
			this.$u.get('/app/common/type/3').then(res => {
				if (res.code == 0) {
					this.registerCode = res.data.value
				}
			});
		},
		methods: {
			isShowAgree() {
				//是否选择协议
				this.showAgree = !this.showAgree;
			},
			showMa() {
				//查询官方邀请码
				this.$Request.getT('/common/type/88').then(res => {
					if (res.code == 0) {
						this.invitation = res.data.value;
					}
				});
			},
			sendMsg() {
				const {
					mobile
				} = this;
				if (!mobile) {
					uni.showToast({
						title: '请输入手机号',
						icon: 'none',
						duration: 1000
					})
				} else if (mobile.length !== 11) {
					uni.showToast({
						title: '请输入正确的手机号',
						icon: 'none',
						duration: 1000
					})
				} else {
					uni.showLoading({
						title: '正在发送验证码...'
					})
					this.$u.get('/app/Login/sendMsg/' + mobile + '/login').then(res => {
						if (res.code === 0) {
							this.sending = true;
							uni.showToast({
								title: '验证码发送成功请注意查收',
								icon: 'none',
								duration: 1000
							})
							this.countDown();
							uni.hideLoading();
						} else {
							uni.hideLoading();
							uni.showModal({
								showCancel: false,
								title: '短信发送失败',
								content: res.msg ? res.msg : '请一分钟后再获取验证码'
							});
						}
					});
				}
			},
			countDown() {
				const {
					count
				} = this;
				if (count === 1) {
					this.count = 60;
					this.sending = false;
					this.sendTime = '获取验证码';
				} else {
					this.count = count - 1;
					this.sending = true;
					this.sendTime = count - 1 + '秒后重新获取';
					setTimeout(this.countDown.bind(this), 1000);
				}
			},
			inputChange(e) {
				const key = e.currentTarget.dataset.key;
				this[key] = e.detail.value;
			},
			navBack() {
				uni.navigateBack();
			},

			navTo(url) {
				uni.navigateTo({
					url
				});
			},
			toLogin() {
				const {
					mobile,
					password,
					// code,
					showAgree,
					invitation,
					registerCode,
					qdCodeion
				} = this;
				if (!mobile) {
					uni.showToast({
						title: '请输入账号',
						icon: 'none',
						duration: 1000
					})
					return
				}
				// if (!code) {
				// 	uni.showToast({
				// 		title: '请输入验证码',
				// 		icon: 'none',
				// 		duration: 1000
				// 	})
				// 	return
				// }
				if (!password) {
					uni.showToast({
						title: '请设置密码',
						icon: 'none',
						duration: 1000
					})
					return
				}
				if (password.length < 6) {
					uni.showToast({
						title: '密码位数必须大于六位',
						icon: 'none',
						duration: 1000
					})
					return
				}
				if (invitation.length == 0 && registerCode == '是') {
					uni.showToast({
						title: '请输入邀请码',
						icon: 'none',
						duration: 1000
					})
					return
				}
				if (!showAgree) {
					uni.showToast({
						title: '请先同意《隐私政策》和《用户协议》',
						icon: 'none',
						duration: 1000
					})
					return
				}
				this.logining = true;
				uni.showLoading({
					title: '注册中...'
				})
				let platform = ''
				// #ifdef APP
				platform = 'app'
				// #endif
				// #ifdef H5
				platform = 'h5'
				// #endif
				this.$u.post('/app/Login/registerCode?password=' + password + '&phone=' + mobile + '&msg=111111' +
					'&inviterCode=' + invitation + '&platform=' + platform + '&qdCode=' + qdCodeion).then(res => {
					if (res.code === 0) {
						// this.$queue.remove('invitation');
						uni.setStorageSync('token', res.token)
						uni.setStorageSync('userId', res.user.userId)
						uni.setStorageSync('phone', res.user.phone)
						uni.setStorageSync('invitationCode', res.user.invitationCode)
						//设置渠道码
						if (res.user.qdCod) {
							uni.setStorageSync('qdCod', res.user.qdCod)
						}

						uni.showToast({
							title: '注册成功',
							icon: 'none'
						})
						setTimeout(function() {
							uni.switchTab({
								url: '/pages/index/index'
							});
						}, 1000)
						// this.getUserInfo(res.userId, res.token);
					} else {
						uni.hideLoading();
						uni.showModal({
							showCancel: false,
							title: '注册失败',
							content: res.msg
						});
					}
				});
			},
			getUserInfo(userId, token) {
				this.$u.api.userinfo().then(res => {
					if (res.code === 0) {
						// #ifdef APP-PLUS
						if (uni.getSystemInfoSync().platform == "android") {
							let clientid = plus.push.getClientInfo().clientid;
							this.$Request.postT('/appLogin/updateClientId?clientId=' + clientid + '&userId=' +
								userId).then(res => {

							});
						}
						// #endif
						uni.setStorageSync('image_url', res.data.imageUrl ? res.data.imageUrl :
							'/static/img/common/logo.jpg')
						uni.setStorageSync('relation_id', res.data.relationId)
						uni.setStorageSync('relation', res.data.invitationCode)
						uni.setStorageSync('grade', res.data.grade)
						uni.setStorageSync('phone', res.data.phone)
						uni.setStorageSync('token', res.token)
						uni.setStorageSync('userId', res.data.userId)
						uni.setStorageSync('isInvitation', res.data.isInvitation)
						uni.setStorageSync('userName', res.data.userName ? res.data.userName : res.data.phone)

						// this.$queue.setData('image_url', res.data.imageUrl ? res.data.imageUrl : '/static/img/common/logo.jpg');
						// this.$queue.setData('relation_id', res.data.relationId);
						// this.$queue.setData('relation', res.data.invitationCode);
						// this.$queue.setData('grade', res.data.grade);
						// this.$queue.setData('mobile', res.data.mobile);
						// this.$queue.setData('isInvitation', res.data.isInvitation);
						// this.$queue.setData('nickName', res.data.nickName ? res.data.nickName : res.data.phone);
						// this.$queue.setData('gender', parseInt(res.data.gender));
						uni.switchTab({
							url: '/pages/index/index'
						});
					} else {
						uni.showModal({
							showCancel: false,
							title: '登录失败',
							content: res.msg
						});
						this.$queue.logout();
					}
					uni.hideLoading();
				})
				// this.$Request.postJson('/app/selectUserById?userId=' + userId).then(res => {
				// 	if (res.code === 0) {
				// 		// #ifdef APP-PLUS
				// 		if (uni.getSystemInfoSync().platform == "android") {
				// 			let clientid = plus.push.getClientInfo().clientid;
				// 			this.$Request.postT('/appLogin/updateClientId?clientId=' + clientid + '&userId=' + userId).then(res => {

				// 			});
				// 		}
				// 		// #endif
				// 		this.$queue.setData('image_url', res.data.imageUrl ? res.data.imageUrl : '/static/img/common/logo.jpg');
				// 		this.$queue.setData('relation_id', res.data.relationId);
				// 		this.$queue.setData('relation', res.data.invitationCode);
				// 		this.$queue.setData('grade', res.data.grade);
				// 		this.$queue.setData('mobile', res.data.mobile);
				// 		this.$queue.setData('isInvitation', res.data.isInvitation);
				// 		this.$queue.setData('nickName', res.data.nickName ? res.data.nickName : res.data.phone);
				// 		this.$queue.setData('gender', parseInt(res.data.gender));
				// 		uni.switchTab({
				// 			url: '/pages/index/index'
				// 		});
				// 	} else {
				// 		uni.showModal({
				// 			showCancel: false,
				// 			title: '登录失败',
				// 			content: res.msg
				// 		});
				// 		this.$queue.logout();
				// 	}
				// 	uni.hideLoading();
				// });
			}
		}
	};
</script>

<style lang="scss">
	page {
		background: #ffffff;
	}

	.footer {
		padding-left: 140upx;
		margin-top: 32upx;
		text-align: center;
		display: flex;
	}

	.send-msg {
		border-radius: 30px;
		color: white;
		height: 30px;
		font-size: 14px;
		line-height: 30px;
		background: #ff7581;
	}

	.send-msgs {
		border-radius: 30px;
		color: #999999;
		height: 30px;

		font-size: 14px;
		line-height: 30px;
		background: white;
	}

	.container {
		padding-top: 32upx;
		position: relative;
		width: 100%;
		height: 100%;
		overflow: hidden;
		background: #ffffff;
	}

	.wrapper {
		position: relative;
		z-index: 90;
		background: #ffffff;
		padding-bottom: 20px;
	}

	.input-content {
		padding: 0 20px;
	}


	.confirm-btn {
		width: 300px;
		height: 42px;
		line-height: 42px;
		// border-radius: 30px;
		margin-top: 40px;
		background: #22a52d;
		color: #ffffff;
		font-size: 32rpx;

		&:after {
			border-radius: 60px;
		}
	}
</style>